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Foreword 



This Technical Specification has been produced by the 3 r Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 
where: 

x the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 



The present document is part 8 of a multi-part TS covering the 3 r Generation Partnership Project: Technical 
Specification Group Core Network; Open Service Access (OSA); Application Programming Interface (API), as 
identified below. The API specification (3GPP TS 29.198) is structured in the following Parts: 



Parti 
Part 2 
Part 3 
Part 4 



Part 5: 
Part 6: 
Part 7: 
Part 8: 

Part 9: 
Part 10 
Part 11 
Part 12 
Part 13 
Part 14 



"Overview"; 

"Common Data Definitions"; 

"Framework"; 

"Call Control"; 

Sub-part 1: "Call Control Common Definitions"; 

Sub-part 2: "Generic Call Control SCF"; 

Sub-part 3: "Multi-Party Call Control SCF"; 

Sub-part 4: "Multi-Media Call Control SCF"; 

Sub-part 5: "Conference Call Control SCF"; 

"User Interaction SCF"; 

"Mobility SCF"; 

"Terminal Capabilities SCF"; 

"Data Session Control SCF"; 

"Generic Messaging SCF"; 

"Connectivity Manager SCF"; 

"Account Management SCF"; 

"Charging SCF". 

"Policy Management SCF"; 

"Presence and Availability Management SCF"; 



(new in 3GPP Release 5) 
(new in 3GPP Release 5) 
(new in 3GPP Release 5) 
(new in 3GPP Release 5) 
(not part of 3GPP Release 5) 



(not part of 3GPP Release 5) 
(not part of 3GPP Release 5) 



(new in 3GPP Release 5) 
(new in 3GPP Release 5) 



The Mapping specification of the OSA APIs and network protocols (3GPP TR 29.998) is also structured as above. 
A mapping to network protocols is however not applicable for all Parts, but the numbering of Parts is kept. 
Also in case a Part is not supported in a Release, the numbering of the parts is maintained. 
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Table: Overview of the OSA APIs & Protocol Mappings 29.198 & 29.998-family 



OSA API specifications 29.198-family 


OSA API Mapping - 29.998-family 


29.198-01 


Overview 


29.998-01 


Overview 


29.198-02 


Common Data Definitions 


29.998-02 


Not Applicable 


29.198-03 


Framework 


29.998-03 


Not Applicable 


Call 
Control 
(CC) SCF 


29.198- 
04-1 

Common 
CC data 
definitions 


29.198- 
04-2 
Generic 
CCSCF 


29.198- 
04-3 
Multi- 
Party CC 
SCF 


29.198- 
04-4 
Multi- 
media CC 
SCF 


29.998-04-1 


Generic Call Control - CAP mapping 


29.998-04-2 


Generic Call Control - INAP mapping 


29.998-04-3 


Generic Call Control - Megaco mapping 


29.998-04-4 


Multiparty Call Control - SIP mapping 


29.198-05 


User Interaction SCF 


29.998-05-1 


User Interaction - CAP mapping 


29.998-05-2 


User Interaction - INAP mapping 


29.998-05-3 


User Interaction - Megaco mapping 


29.998-05-4 


User Interaction - SMS mapping 


29.198-06 


Mobility SCF 


29.998-06 


User Status and User Location - MAP mapping 


29.198-07 


Terminal Capabilities SCF 


29.998-07 


Not Applicable 


29.198-08 


Data Session Control SCF 


29.998-08 


Data Session Control - CAP mapping 


29.198-09 


Generic Messaging SCF 


29.998-09 


Not Applicable 


29.198-10 


Connectivity Manager SCF 


29.998-10 


Not Applicable 


29.198-11 


Account Management SCF 


29.998-11 


Not Applicable 


29.198-12 


Charging SCF 


29.998-12 


Not Applicable 


29.198-13 


Policy Management SCF 


29.998-13 


Not Applicable 


29.198-14 


Presence & Availability Management SCF 


29.998-14 


Not Applicable 
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Scope 



The present document is Part 8 of the Stage 3 specification for an Application Programming Interface (API) for Open 
Service Access (OSA). 

The OSA specifications define an architecture that enables application developers to make use of network functionality 
through an open standardised interface, i.e. the OSA APIs. The concepts and the functional architecture for the OSA are 
contained in 3GPP TS 23.127 [3]. The requirements for OSA are contained in 3GPP TS 22.127 [2]. 

The present document specifies the Data Session Control Service Capability Feature (SCF) aspects of the interface. All 
aspects of the Data Session Control SCF are defined here, these being: 

Sequence Diagrams 

Class Diagrams 

Interface specification plus detailed method descriptions 

State Transition diagrams 

Data definitions 

IDL Description of the interfaces 

WSDL Description of the interfaces 

The process by which this task is accomplished is through the use of object modelling techniques described by the 
Unified Modelling Language (UML). 

This specification has been defined jointly between 3GPP TSG CN WG5, ETSI SPAN 12 and the Parlay Consortium, 
in co-operation with a number of JAIN™ Community member companies. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 29.198-1 "Open Service Access; Application Programming Interface; Part 1: 

Overview" . 

[2] 3GPP TS 22.127: "Stage 1 Service Requirement for the Open Service Access (OSA) (Release 5)". 

[3] 3GPP TS 23.127: "Virtual Home Environment (Release 5)". 

[4] ISO 4217 (1995): "Codes for the representation of currencies and funds". 



ETSI 



3GPP TS 29.198-08 version 5.5.0 Release 5 



ETSI TS 129 198-8 V5.5.0 (2004-04) 



3.1 



Definitions and abbreviations 



Definitions 



For the purposes of the present document, the terms and definitions given in TS 29.198-1 [1] apply. 

3.2 Abbreviations 

For the purposes of the present document, the abbreviations given in TS 29.198-1 [1] apply. 



4 Data Session Control SCF 

The Data Session Control network SCF consists of two interfaces: 

1) Data Session manager, containing management functions for data session related issues; 

2) Data Session, containing methods to control a session. 

A session can be controlled by one Data Session Manager only. Data Session Manager can control several sessions. 



Data Session 
Manager 



1 n 



Data Session 



NOTE: The term "data session" is used in a broad sense to describe a data connection/session. For example, it 
comprises a PDP context in GPRS. 

Figure 1 : Data Session control interfaces usage relationship 

The Data Session Control SCFs are described in terms of the methods in the Data Session Control interfaces. Table 1 
gives an overview of the Data Session Control methods and to which interfaces these methods belong. 

Table 1 : Overview of Data Session Control interfaces and their methods 



Data Session Manager 


Data Session 


createNotification 


connectReq 


destroyNotification 


connectRes 


dataSessionNotificationlnterrupted 


connectErr 


dataSessionNotificationContinued 


release 


reportNotification 


superviseDataSessionReq 


dataSessionAborted 


superviseDataSessionRes 


getNotification 


superviseDataSessionErr 


changeNotification 


dataSessionFaultDetected 


enableNotifications 


setAdviceofCharge 


disableNotifications 


setDataSessionChargePlan 



The session manager interface provides the management functions to the data session service capability features. The 
application programmer can use this interface to enable or disable data session-related event notifications. 

The following clauses describe each aspect of the Data Session Control Service Capability Feature (SCF). 

The order is as follows: 

• the Sequence diagrams give the reader a practical idea of how each of the SCF is implemented; 

• the Class relationships clause shows how each of the interfaces applicable to the SCF, relate to one another; 

• the Interface specification clause describes in detail each of the interfaces shown within the Class diagram part; 
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• 



the State Transition Diagrams (STD) show the transition between states in the SCF. The states and transitions 
are well-defined; either methods specified in the Interface specification or events occurring in the underlying 
networks cause state transitions; 

• the Data definitions section show a detailed expansion of each of the data types associated with the methods 
within the classes. Note that some data types are used in other methods and classes and are therefore defined 
within the Common Data types part of this specification. 

4.1 General requirements on support of methods 

An implementation of this API which supports or implements a method described in the present document, shall 
support or implement the functionality described for that method, for at least one valid set of values for the parameters 
of that method. 

Where a method is not supported by an implementation of a Service interface, the exception 
P_METHOD_NOT_SUPPORTED shall be returned to any call of that method. 

Where a method is not supported by an implementation of an Application interface, a call to that method shall be 
possible, and no exception shall be returned. 



Sequence Diagrams 



5.1 Network Controlled Notifications 

The following sequence diagram shows how an application can receive notifications that have not been created by the 
application, but are provisioned from within the network. 
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AppLogic 



IpAppDataSessionControlManager 

i 

1 : new ( ) 



IpDataSessionControlManager 



*a 



2: e|nableNotifications( ) 



-> 



4: 'forward event' 



IT 



3: reportNotification( 



'-<- 



6: 'forward event' 



(f- 



5: reportNotification( 



h<- 



7: disableNotifications( ) 



^> 



1: The application is started. The application creates a new IpAppDataSessionControlManager to handle callbacks. 

2: The enableNotifications method is invoked on the IpDataSessionControlManager interface to indicate that the 
application is ready to receive notifications that are created in the network. For illustrative purposes we assume 
notifications of type "B" are created in the network. 

3: When a network created trigger occurs the application is notified on the callback interface. 

4: The event is forwarded to the application. 

5: When a network created trigger occurs the application is notified on the callback interface. 

6: The event is forwarded to the application. 

7: When the application does not want to receive notifications created in the network anymore, it invokes 
disableNotifications on the IpDataSessionConrolManager interface. From now on the gateway will not send any 
notifications to the application that are created in the network. The application will still receive notifications that it has 
created himself until the application removes them. 



5.2 



Enable Data Session Notification 
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Application 



Data Session Manager : 
IpDataSessionControlManager 



1: createNotification( ) 



^ 



Data Session : 
IpDataSession 



5.3 Address Translation With Charging 
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Application 



Data Session Manager : 
IpDataSessionControlManager 



1 : createNotification( ) 



3: 'translate address' 
< — ^ 



2: reportNotification() 



<r 



<- 



1^ 



4: setGallback( ) 



5: superviseDataSessionReq( 



6: connectReq( 



7: superviseDataSessionResO 



8: superviseDa^aSessionReq( 



9: superviseDataSessionResO 



10: Con|iectRes( ) 



Data Session : 
IpDataSession 



-> 



> 



->| 



->r 



6 Class Diagrams 



Data Session Control Class Diagram: 
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«lnterface» 
Iplnterface 

(from csapi) 



«lnterface» 
IpAppDataSessionControlManager 

(from dsc) 



♦dataSessionAborted() 
%eportNotification() 
^dataSessionNotificationContinuedO 
%JataSessionNotificationlnternjpted() 



A 



«uses» 



0..n 



«lnterface» 
IpAppDataSession 

(from dsc) 



^connect ResO 
^connect Err() 

^superviseDataSessionRes() 
^superviseDataSessionErr() 
♦dataSess ionFau It Detect ed() 



«uses» 



«lnterface» 
IpDataSessionControlManager 

(from dsc) 



^«deprecated» createNotification() 
*destroyNotification() 
*changeNotification() 
*«deprecated» getNotification() 
^«new» enableNotifications() 
^«new» disableNotifications() 
♦«new» getNotifications() 
♦«new» createNotificationsQ 



0..n 



«lnterface» 
IpDataSession 

(from dsc) 



♦connectReq() 

%elease() 

^superviseDataSessionReq() 

*setDataSessionChargePlan() 

♦setAdviceOfCharge() 

*deassignDataSession() 

♦continueProcess ing() 



V7 



«lnterface» 
IpService 

(from csapi) 



►setCallback() 
►setCallbackWithSessionlD() 



Figure: Package Overview 
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7 The Service Interface Specifications 

7.1 Interface Specification Format 

This clause defines the interfaces, methods and parameters that form a part of the API specification. The Unified 
Modelling Language (UML) is used to specify the interface classes. The general format of an interface specification is 
described below. 

7.1.1 Interface Class 

This shows a UML interface class description of the methods supported by that interface, and the relevant parameters 
and types. The Service and Framework interfaces for enterprise-based client applications are denoted by classes with 
name Ip<name>. The callback interfaces to the applications are denoted by classes with name IpApp<name>. For 
the interfaces between a Service and the Framework, the Service interfaces are typically denoted by classes with name 
IpSvc<name>, while the Framework interfaces are denoted by classes with name IpFw<name> 

7.1.2 Method descriptions 

Each method (API method "call") is described. Both synchronous and asynchronous methods are used in the API. 
Asynchronous methods are identified by a 'Req' suffix for a method request, and, if applicable, are served by 
asynchronous methods identified by either a 'Res' or 'Err' suffix for method results and errors, respectively. To handle 
responses and reports, the application or service developer must implement the relevant IpApp<name> or 
IpSvc<name> interfaces to provide the callback mechanism. 

7.1.3 Parameter descriptions 

Each method parameter and its possible values are described. Parameters described as 'in' represent those that must have 
a value when the method is called. Those described as 'out' are those that contain the return result of the method when 
the method returns. 

7.1.4 State Model 

If relevant, a state model is shown to illustrate the states of the objects that implement the described interface. 

7.2 Base Interface 

7.2.1 Interface Class Iplnterface 

All application, framework and service interfaces inherit from the following interface. This API Base Interface does not 
provide any additional methods. 
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«lnterface» 
Iplnterface 



7.3 Service Interfaces 
7.3.1 Overview 

The Service Interfaces provide the interfaces into the capabilities of the underlying network - such as call control, user 
interaction, messaging, mobility and connectivity management. 

The interfaces that are implemented by the services are denoted as "Service Interface". The corresponding interfaces 
that must be implemented by the application (e.g. for API callbacks) are denoted as "Application Interface". 

7.4 Generic Service Interface 
7.4.1 Interface Class IpService 

Inherits from: Iplnterface 

All service interfaces inherit from the following interface. 



«lnterface» 
IpService 



setCallback (applnterface : in IplnterfaceRef) : void 

setCallbackWithSessionID (applnterface : in IplnterfaceRef, sessionID : in TpSessionID) : void 



7.4.1.1 Method setCallback() 

This method specifies the reference address of the callback interface that a service uses to invoke methods on the 
application. It is not allowed to invoke this method on an interface that uses SessionlDs. 

Parameters 

applnterface : in IplnterfaceRef 

Specifies a reference to the application interface, which is used for callbacks. 

Raises 

TpCommonExceptions , P_INVALID_INTERFACE_TYPE 
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7.4.1.2 Method setCallbackWithSessionlD() 

This method specifies the reference address of the application's callback interface that a service uses for interactions 
associated with a specific session ID: e.g. a specific call, or call leg. It is not allowed to invoke this method on an 
interface that does not use SessionlDs. 

Parameters 

applnterface : in IpInterfaceRef 

Specifies a reference to the application interface, which is used for callbacks. 

sessionID : in TpSessionID 

Specifies the session for which the service can invoke the application's callback interface. 

Raises 

TpCommonExceptions, P_INVALID_SESSION_ID, P_INVALID_INTERFACE_TYPE 



8 Data Session Control Interface Classes 

The Data Session Control provides a means to control per data session basis the establishment of a new data session. 
This means especially in the GPRS context that the establishment of a PDP session is modelled not the attach/detach 
mode. Change of terminal location is assumed to be managed by the underlying network and is therefore not part of the 
model. The underlying assumption is that a terminal initiates a data session and the application can reject the request for 
data session establishment, can continue the establishment or can continue and change the destination as requested by 
the terminal. 

The modelling is similar to the Generic Call Control but assumes a simpler underlying state model. An 
IpDataSessionControlManager object and an IpDataSession object are the interfaces used by the application, whereas 
the IpAppDataSessionControlManager and the IpAppDataSession interfaces are implemented by the application. 

8.1 Interface Class IpAppDataSession 

Inherits from: Iplnterface. 

The application side of the data session interface is used to handle data session request responses and state reports. 



«lnterface» 
IpAppDataSession 



connectRes (dataSessionID : in TpSessionID, eventReport : in TpDataSessionReport, assignmentID : in 
TpAssignmentID) : void 

connectErr (dataSessionID : in TpSessionID, errorlndication : in TpDataSessionError, assignmentID : in 
TpAssignmentID) : void 

superviseDataSessionRes (dataSessionID : in TpSessionID, report : in TpDataSessionSuperviseReport, 
usedVolume : in TpDataSessionSuperviseVolume, qualityOf Service : in TpDataSessionQosClass) : void 

superviseDataSessionErr (dataSessionID : in TpSessionID, errorlndication : in TpDataSessionError) : void 

dataSessionFaultDetected (dataSessionID : in TpSessionID, fault : in TpDataSessionFault) : void 
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8.1.1 Method connectResQ 



This asynchronous method indicates that the request to connect a data session with the destination party was successful, 
and indicates the response of the destination party (e.g. connected, disconnected). 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

eventReport : in TpDataSessionReport 

Specifies the result of the request to connect the data session. It includes the network event, date and time, monitoring 
mode, negotiated quality of service and event specific information such as release cause. 

assignmentID : in TpAssignmentID 



8.1.2 Method connectErr() 

This asynchronous method indicates that the request to connect a data session with the destination party was 
unsuccessful, e.g. an error detected in the network or the data session was abandoned. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID. 

errorlndication : in TpDataSessionError 

Specifies the error which led to the original request failing. 

assignmentID : in TpAssignmentID 



8.1.3 Method superviseDataSessionResQ 



This asynchronous method reports a data session supervision event to the application. In addition, it may also be used 
to notify the application of a newly negotiated set of Quality of Service parameters during the active life of the data 
session. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session. 

report : in TpDataSessionSuperviseReport 

Specifies the situation, which triggered the sending of the data session supervision response. 

usedVolume : in TpDataSessionSuperviseVolume 

Specifies the used volume for the data session supervision (in the same unit as specified in the request). 
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qualityOfService : in TpDataSessionQosClass 

Specifies the newly negotiated Quality of Service parameters for the data session. 



8.1.4 Method superviseDataSessionErr() 

This asynchronous method reports a data session supervision error to the application. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session ID. 

errorlndication : in TpDataSessionError 

Specifies the error which led to the original request failing. 



8.1.5 Method dataSessionFaultDetected() 

This method indicates to the application that a fault in the network has been detected which cannot be communicated by 
a network event, e.g., when the user aborts before any establishment method is called by the application. 

The system purges the Data Session object. Therefore, the application has no further control of data session processing. 
No report will be forwarded to the application. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session ID of the Data Session object in which the fault has been detected. 

fault : in TpDataSessionFault 

Specifies the fault that has been detected. 



8.2 Interface Class IpAppDataSessionControlManager 

Inherits from: Iplnterface. 

The data session control manager application interface provides the application data session control management 
functions to the data session control SCF. 
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«lnterface» 
IpAppDataSessionControlManager 



dataSessionAborted (dataSession : in TpSessionID) : void 

reportNotification (dataSessionReference : in TpDataSessionldentifier, eventlnfo : in 
TpDataSessionEventlnfo, assignmentID : in TpAssignmentID) : IpAppDataSessionRef 

dataSessionNotificationContinued () : void 

dataSessionNotificationlnterrupted () : void 



8.2.1 Method dataSessionAborted() 

This method indicates to the application that the Data Session object has aborted or terminated abnormally. No further 
communication will be possible between the Data Session object and the application. 

Parameters 

dataSession : in TpSessionID 

Specifies the session ID of the data session that has aborted or terminated abnormally. 



8.2.2 Method reportNotification() 

This method notifies the application of the arrival of a data session-related event. 

If this method is invoked with a monitor mode of P_DATA_SESSION_MONITOR_MODE_INTERRUPT, then the 
application has control of the data session. If the application does nothing with the data session within a specified time 
period (the duration of which forms a part of the service level agreement), then the data session in the network shall be 
released and dataSessionFaultDetected() shall be invoked, giving a fault code of 
P_DATA_SESSION_TIMEOUT_ON_INTERRUPT. 

Returns appDataSession : Specifies a reference to the application object which implements the callback interface for the 
new data session. If the application has previously explicitly passed a reference to the IpAppDataSession interface using 
a setCallbackWithSessionID() invocation, this parameter may be null, or if supplied must be the same as that provided 
during the setCallbackWithSessionID(). 

This parameter will be null if the notification is in NOTIFY mode. 

Parameters 

dataSessionReference : in TpDataSessionldentifier 

Specifies the session ID and the reference to the Data Session object to which the notification relates. If the notification 
is being given in NOTIFY mode, this parameter shall be ignored by the application client implementation, and 
consequently the implementation of the SCS entity invoking reportNotification may populate this parameter as it 
chooses. 

eventlnfo : in TpDataSessionEventlnfo 

Specifies data associated with this event. This data includes the destination address provided by the end-user and the 
quality of service requested or negotiated for the data session. 
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assignmentID : in TpAssignmentID 

Specifies the assignment id which was returned by the createNotification() method. The application can use assignment 
ID to associate events with event-specific criteria and to act accordingly. 

Returns 
IpAppDataSessionRef 



8.2.3 Method dataSessionNotificationContinued() 

This method indicates to the application that all event notifications are resumed. 

Parameters 

No Parameters were identified for this method 

8.2.4 Method dataSessionNotificationlnterrupted() 

This method indicates to the application that event notifications will no longer be sent (for example, due to faults 
detected). 

Parameters 

No Parameters were identified for this method 



8.3 Interface Class IpDataSession 

Inherits from: IpService. 

The Data Session interface provides basic methods for applications to control data sessions. This interface shall be 
implemented by a Data Session Control SCF. As a minimum requirement, the connectReq(), release(), 
deassignDataSessionQ and continueProcessing() methods shall be implemented. 
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«lnterface» 
IpDataSession 



connectReq (dataSessionID : in TpSessionID, responseRequested : in TpDataSessionReportRequestSet, 
targetAddress : in TpAddress) : TpAssignmentID 

release (dataSessionID : in TpSessionID, cause : in TpDataSessionReleaseCause) : void 

superviseDataSessionReq (dataSessionID : in TpSessionID, treatment : in 

TpDataSessionSuperviseTreatment, bytes : in TpDataSessionSuperviseVolume) : void 

setDataSessionChargePlan (dataSessionID : in TpSessionID, dataSessionChargePlan : in 
TpDataSessionChargePlan) : void 

setAdviceOfCharge (dataSessionID : in TpSessionID, aoClnfo : in TpAoClnfo, tariffSwitch : in TpDuration) 
void 

deassignDataSession (dataSessionID : in TpSessionID) : void 

continueProcessing (dataSessionID : in TpSessionID) : void 



8.3.1 Method connectReq() 



This asynchronous method requests the connection of a data session with the destination party (specified in the 
parameter TargetAddress). The Data Session object is not automatically deleted if the destination party disconnects 
from the data session. 

Returns assignmentID : Specifies the ID assigned to the request. The same ID will be returned in the connectRes or Err. 
This allows the application to correlate the request and the result. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID. 

responseRequested : in TpDataSessionReportRequestSet 

Specifies the set of observed data session events that will result in a connectRes() being generated. 

targetAddress : in TpAddress 

Specifies the address of destination party. 

Returns 
TpAssignmentID 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_ADDRESS, 
P INVALID SESSION ID 



8.3.2 Method releaseQ 



This method requests the release of the data session and associated objects. 
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Parameters 

dataSessionID : in TpSessionID 

Specifies the session. 

cause : in TpDataSessionReleaseCause 

Specifies the cause of the release. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_SESSION_ID 



8.3.3 Method superviseDataSessionReqQ 



The application calls this method to supervise a data session. The application can set a granted data volume for this data 
session. If an application calls this function before it calls a connectReq() or a user interaction function the time 
measurement will start as soon as the data session is connected. The Data Session object will exist after the data session 
has been terminated if information is required to be sent to the application at the end of the data session. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the data session. 

treatment : in TpDataSessionSuperviseTreatment 

Specifies how the network should react after the granted data volume has been sent. 

bytes : in TpDataSessionSuperviseVolume 

Specifies the granted number of bytes that can be transmitted for the data session. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_SESSION_ID 



8.3.4 Method setDataSessionChargePlan() 

Allows an application to include charging information in network generated CDR. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

dataSessionChargePlan : in TpDataSessionChargePlan 

Specifies the charge plan used. 
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Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_SESSION_ID 



8.3.5 Method setAdviceOfCharge() 

This method allows the application to determine the charging information that will be sent to the end-users terminal. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

aoCInfo : in TpAoCInfo 

Specifies two sets of Advice of Charge parameter according to GSM. 

tariffSwitch : in TpDuration 

Specifies the tariff switch that signifies when the second set of AoC parameters becomes valid. 

Raises 

TpCommonExceptions , P_INVALID_NETWORK_STATE , 
P INVALID TIME AND DATE FORMAT 



8.3.6 Method deassignDataSessionQ 



This method requests that the relationship between the application and the data session and associated objects be de- 
assigned. It leaves the data session in progress, however, it purges the specified data session object so that the 
application has no further control of data session processing. If a data session is de-assigned that has event reports, data 
session information reports requested, then these reports will be disabled and any related information discarded. 

The application should always either release or deassign the data session when it is finished with the data session, 
unless dataSessionFaultDetected is received by the application. 

Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID 



8.3.7 Method continueProcessingQ 



This operation continues processing of the data session. Applications can invoke this operation after session handling 
was interrupted due to detection of a notification or event the application subscribed its interest in. 
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Parameters 

dataSessionID : in TpSessionID 

Specifies the session ID of the data session. 

Raises 

TpCommonExceptions, P_INVALID_SESSION_ID, P_INVALID_NETWORK_STATE 



8.4 Interface Class IpDataSessionControlManager 

Inherits from: IpService. 

This interface is the 'SCF manager' interface for Data Session Control. This interface shall be implemented by a Data 
Session Control SCF. As a minimum requirement, the createNotifications() and destroyNotification(), or the 
enableNotifications() and disableNotificationsQ methods shall be implemented. 



«lnterface» 
IpDataSessionControlManager 



«deprecated» createNotification (appDataSessionControlManager : in 

IpAppDataSessionControlManagerRef, eventCriteria : in TpDataSessionEventCriteria) : TpAssignmentID 

destroyNotification (assignmentID : in TpAssignmentID) : void 

changeNotification (assignmentID : in TpAssignmentID, eventCriteria : in TpDataSessionEventCriteria) : 
void 

«deprecated» getNotification () : TpDataSessionEventCriteria 

«new» enableNotifications (appDataSessionControlManager : in IpAppDataSessionControlManagerRef) : 
TpAssignmentID 

«new» disableNotifications () : void 

«new» getNotifications () : TpDataSessionEventCriteriaResultSet 

«new» createNotifications (appDataSessionControlManager : in IpAppDataSessionControlManagerRef, 
eventCriteria : in TpDataSessionEventCriteria) : TpAssignmentID 



8.4.1 Method «deprecated» createNotification() 

This method is deprecated and will be removed in a later release. It is replaced with createNotifications(). 

This method is used to enable data session notifications so that events can be sent to the application. This is the first step 
an application has to do to get initial notifications of data session happening in the network. When such an event 
happens, the application will be informed by reportNotification(). In case the application is interested in other events 
during the context of a particular data session it has to use the connectReq() method on the data session object. The 
application will get access to the data session object when it receives the reportNotification(). 

The createNotification method is purely intended for applications to indicate their interest to be notified when certain 
data session events take place. It is possible to subscribe to a certain event for a whole range of addresses, e.g. the 
application can indicate it wishes to be informed when a data session is setup to any number starting with 800. 
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If some application already requested notifications with criteria that overlap the specified criteria or the specified 
criteria overlap with criteria already present in the network (when provisioned from within the network), the request is 
refused with P_IN VALID_CRITERIA. The criteria are said to overlap if both originating and terminating ranges 
overlap and the same number plan is used. 

If a notification is requested by an application with monitor mode set to notify, then there is no need to check the rest of 
the criteria for overlapping with any existing request as the notify mode does not give control of a data session. Only 
one application can place an interrupt request if the criteria overlaps. 

If the same application requests two notifications with exactly the same criteria but different callback references, the 
second callback will be treated as an additional callback. Both notifications will share the same assignmentlD. The 
gateway will always use the most recent callback. In case this most recent callback fails the second most recent is used. 
In case the createNotification contains no callback, at the moment the application needs to be informed the gateway will 
use as callback the callback that has been registered by setCallback(). 

Returns assignmentlD : Specifies the ID assigned by the Data Session Manager object for this newly-enabled event 
notification. 

Parameters 

appDataSessionControlManager : in IpAppDataSessionControlManagerRef 

If this parameter is set (i.e. not NULL) it specifies a reference to the application interface which is used for callbacks. If 
set to NULL, the application interface defaults to the interface specified via the setCallback() method. 

eventCriteria : in TpDataSessionEventCriteria 

Specifies the event specific criteria used by the application to define the event required. Individual addresses or address 
ranges may be specified for destination and/or origination. Examples of events are "Data Session set up". 

Returns 
TpAssignmentID 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_CRITERIA, 
P INVALID EVENT TYPE 



8.4.2 Method destroyNotificationQ 



This method is used by the application to disable data session notifications. This method only applies to notifications 
created with createNotification(). 

Parameters 

assignmentlD : in TpAssignmentID 

Specifies the assignment ID given by the data session manager object when the previous createNotification() was done. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_ASSIGNMENT_ID 
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8.4.3 Method changeNotificationQ 



This method is used by the application to change the event criteria introduced with the createNotification method. Any 
stored notification request associated with the specified assignmentID will be replaced with the specified events 
requested. 

Parameters 

assignmentID : in TpAssignmentID 

Specifies the ID assigned by the manager interface for the event notification. 

eventCriteria : in TpDataSessionEventCriteria 

Specifies the new set of event criteria used by the application to define the event required. Only events that meet these 
criteria are reported. 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_ASSIGNMENT_ID, 
P_INVALID_CRITERIA, P_INVALID_EVENT_TYPE 



8.4.4 Method «deprecated» getNotification() 

This method is deprecated and its use is discouraged. It will be removed in a later release. It is replaced with 

getNotifications. 

This method is used by the application to query the event criteria set with createNotification or changeNotification. 

Returns eventCriteria : Specifies the event criteria used by the application to define the event required. Only events that 
meet these requirements are reported. 

Parameters 

No Parameters were identified for this method 

Returns 
TpDataSessionEventCriteria 

Raises 

TpCommonExceptions , P_INVALID_NETWORK_STATE 



8.4.5 Method «new» enableNotifications() 

This method is used to indicate that the application is able to receive which are provisioned from within the network 
(i.e. these notifications are NOT set using createNotification() but via, for instance, a network management system). If 
notifications provisioned for this application are created or changed, the application is unaware of this until the 
notification is reported. 

If the same application requests to enable notifications for a second time with a different 

IpAppDataSessionControlManager reference (i.e. without first disabling them), the second callback will be treated as an 
additional callback. The gateway will always use the most recent callback. In case this most recent callback fails the 
second most recent is used. 
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When this method is used, it is still possible to use createNotification() for service provider provisioned notifications on 
the same interface as long as the criteria in the network and provided by createNotification() do not overlap. However, it 
is NOT recommended to use both mechanisms on the same service manager. 

The methods changeNotification(), getNotification(), and destroyNotification() do not apply to notifications provisioned 
in the network and enabled using enableNotifications(). These only apply to notifications created using 
createNotification() . 

Returns assignmentID: Specifies the ID assigned by the manager interface for this operation. This ID is contained in 
any reportNotification() that relates to notifications provisioned from within the network. Repeated calls to 
enableNotificationsQ return the same assignment ID. 



Parameters 

appDataSessionControlManager : in IpAppDataSessionControlManagerRef 

If this parameter is set (i.e. not NULL) it specifies a reference to the application interface, which is used for callbacks. If 
set to NULL, the application interface defaults to the interface specified via the setCallback() method. 

Returns 
TpAssignmentID 

Raises 
TpCommonExceptions 



8.4.6 Method «new» disableNotifications() 

This method is used to indicate that the application is not able to receive notifications for which the provisioning has 
been done from within the network, (i.e. these notifications that are NOT set using createNotification() but via, for 
instance, a network management system). After this method is called, no such notifications are reported anymore. 

Parameters 

No Parameters were identified for this method 

Raises 
TpCommonExceptions 



8.4.7 Method «new» getNotifications() 

This method replaces getNotification(). 

This method is used by the application to query the event criteria set with createNotification or changeNotification. 

Returns eventCriteria: the list of event criteria for the notifications requested by the application. If there is no 
information to return (e.g. no notifications requested by the application), an empty set (zero length) is returned. 

Parameters 

No Parameters were identified for this method 
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Returns 
TpDataSessionEventCriteriaResultSet 

Raises 

TpCommonExceptions , P_INVALID_NETWORK_STATE 

8.4.8 Method «new» createNotifications() 

This method is deprecated and will be removed in a later release. It is replaced with createNotifications(). 

This method is used to enable data session notifications so that events can be sent to the application. This is the first step 
an application has to do to get initial notifications of data session happening in the network. When such an event 
happens, the application will be informed by reportNotification(). In case the application is interested in other events 
during the context of a particular data session it has to use the connectReq() method on the data session object. The 
application will get access to the data session object when it receives the reportNotification(). 

The createNotification method is purely intended for applications to indicate their interest to be notified when certain 
data session events take place. It is possible to subscribe to a certain event for a whole range of addresses, e.g. the 
application can indicate it wishes to be informed when a data session is setup to any number starting with 800. 

If some application already requested notifications with criteria that overlap the specified criteria or the specified 
criteria overlap with criteria already present in the network (when provisioned from within the network), the request is 
refused with P_INVALID_CRITERIA. The criteria are said to overlap if both originating and terminating ranges 
overlap and the same number plan is used. 

If a notification is requested by an application with monitor mode set to notify, then there is no need to check the rest of 
the criteria for overlapping with any existing request as the notify mode does not give control of a data session. Only 
one application can place an interrupt request if the criteria overlaps. 

If the same application requests two notifications with exactly the same criteria but different callback references, the 
second callback will be treated as an additional callback. Both notifications will share the same assignmentlD. The 
gateway will always use the most recent callback. In case this most recent callback fails the second most recent is used. 
In case the createNotification contains no callback, at the moment the application needs to be informed the gateway will 
use as callback the callback that has been registered by setCallback(). 

Returns assignmentlD : Specifies the ID assigned by the Data Session Manager object for this newly-enabled event 
notification. 

Parameters 

appDataSessionControlManager : in IpAppDataSessionControlManagerRef 

If this parameter is set (i.e. not NULL) it specifies a reference to the application interface which is used for callbacks. If 
set to NULL, the application interface defaults to the interface specified via the setCallback() method. 

eventCriteria : in TpDataSessionEventCriteria 

Specifies the event specific criteria used by the application to define the event required. Individual addresses or address 
ranges may be specified for destination and/or origination. Examples of events are "Data Session set up". 

Returns 
TpAssignmentID 

Raises 

TpCommonExceptions, P_INVALID_NETWORK_STATE, P_INVALID_CRITERIA, 
P_INVALID_EVENT_TYPE , P_INVALID_INTERFACE_TYPE 
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9 State Transition Diagrams 

9.1 State Transition Diagrams for IpDataSession 

The state transition diagram shows the application view on the Data Session object. 



IpAppDataSessDsjiControlManager.reporlNotificatJ 
on( P_fevENKqSCS_E STAB LI SHED ) 



lpAppDataSeffiionControlManager.reportNotificaii«n( 
P_EVENT_DSCS_SETUP ) 



" A superviseDataSessioi 




[ no reports requested 



In state Finished a timer mechanism 
should prevent that the object keeps 
occupying resources. In case the timer 
expires, the object should be destroyed 
and dataSessi on Fault Detected should be 
reported to the application. 



Figure : Application view on the Data Session object 

9.1 .1 Network Released State 

In this state the data session has ended. In the case on a normal user disconnection the transition to this state is indicated 
to the application by the disconnect report of connectRes(). But this will only happen if the application requested 
monitoring of the disconnect event before. An abnormal disconnection is indicated by dataSessionFaultDetected(). The 
application may wait for outstanding superviseDataSessionRes(). 

9.1.2 Finished State 

In this state the data session has ended and no further data session related information is to be send to the application. 
The application can only release the data session object. Calling the deassignDataSession() operation has the same 
effect. If the application fails to invoke release() within a certain period of time the gateway should automatically 
release the object and send a timeout indication to the application. 
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9.1 .3 Application Released State 

In this state the application has released the data session object. If supervision has been requested the gateway will 
collect the information and send superviseDataSessionRes() to the application. 

9.1.4 Active State 

In this state a data connection between two parties is being setup or established (refer to the substates for more details). 
The application can request the gateway for a certain type of charging by calling setDataSessionChargePlan(), send 
advice of charge information by calling setAdviceOfCharge(), and request supervision of the data session by calling 
superviseDataSessionReq(). 

9.1.5 Setup State 

The Setup state is reached after a reportNotification() indicates to the application that a data session is interested in 
being connected. If the application is going to connect the two parties by invoking connectReq() it may call the 
charging or supervision methods before. 

9.1.6 Established State 

In this state the data connection is established. If supervision has been requested the application expects the 
corresponding superviseDataSessionResQ. 
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1 Data Session Control Service Properties 

The following table lists properties relevant for the Data Session Control API. 



Property 


Type 


Description/Interpretation 


PJTRIGGERINGj;VENT„TYPES 


INTEGER_SET 


Indicates the static event types supported by the SCS. Static 
events are the events by which applications are initiated. 


P_DYNAMIC_EVENT_TYPES 


INTEGER_SET 


Indicates the dynamic event types supported by the SCS. 
Dynamic events are the events the application can request 
for during the context of a call. 


P_ADDRESSPLAN 


INTEGER_SET 


Indicates the supported address plan (defined in 
TpAddressPlan.) E.g. P_ADDRESS_PLAN_IP. 



The previous table lists properties related to the capabilities of the SCS itself. The following table lists properties that are 
used in the context of the Service Level Agreement, e.g. to restrict the access of applications to the capabilities of the 
SCS. 



Property 


Type 


Description/Interpretation 


PJTRIGGERING^ADDRESSES 


ADDRESS^RANGE_SET 


Indicates for which numbers the notification may be set. For 
terminating notifications it applies to the terminating 
number, for originating notifications it applies only to the 
originating number. 


P_MONITORJVIODE 


INTEGER_SET 


Indicates whether the application is allowed to monitor in 
interrupt and/or notify mode. Set is: 

P_INTERRUPT 

P_NOTIFY 


P_NUMBERS_TO_BE_CHANGED 


INTEGER^SET 


Indicates which numbers the application is allowed to 
change or fill for legs in an incoming call. Allowed value 
set: 

{ P_TARGET_NUMBER j . 


P_CHARGEPLAN_ALLOWED 


INTEGER_SET 


Indicates which charging is allowed in the 
setDataSessionChargePlan indicator. Allowed values: 

{ P_CHARGE_PER_VOLUME, 
P_TRANSPARANT_CHARGING, 

P_CHARGE_PLAN) 


P_CHARGEPLAN_MAPPING 


INTEGER JNTEGER_MAP 


Indicates the mapping of charge plans (we assume they can 
be indicated with integers) to a logical network charge plan 
indicator. When the P_CHARGEPLAN_ALLOWED 
property indicates P_CHARGE_PLAN, then only charge 
plans in this mapping are allowed. 


P_CURRENCY_ALLOWED 


STRING_SET 


Indicates the currencies that are allowed to be set for the 
charge plan in the setDataSessionChargePlan. The valid 
values for the string set are according to ISO-4217:1995. 
E.g. {'EUR', 'NLG'}. 



11 



Data Definitions 



All data types referenced but not defined in this clause are common data definitions which may be found in 
3GPPTS 29.198-2. 
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11.1 Data Session Control Data Definitions 

11.1.1 IpAppDataSession 

Defines the address of an IpAppDataSession Interface. 

11.1.2 IpAppDataSessionRef 

Defines a Reference to type IpAppDataSession 

11.1.3 IpAppDataSessionControlManager 

Defines the address of an IpAppDataSessionControlManager Interface. 

11.1.4 IpAppDataSessionControlManagerRef 

Defines a Reference to type IpAppDataSessionControlManager. 

11.1.5 IpDataSession 

Defines the address of an IpDataSession Interface. 

11.1.6 IpDataSessionRef 

Defines a Reference to type IpDataSession. 

11.1.7 IpDataSessionControlManager 

Defines the address of an IpDataSessionControlManager Interface. 

11.1.8 IpDataSessionControlManagerRef 

Defines a Reference to type IpDataSessionControlManager. 

1 1 .2 Event Notification data definitions 
1 1 .2.1 TpDataSessionEventName 

Defines the names of events being notified with a new call request. The following events are supported. The values may 
be combined by a logical 'OR' function when requesting the notifications. Additional events that can be requested / 
received during the call process are found in the TpDataSessionReportType data-type. 



Name 


Value 


Description 


P_EVENT_NAME_UNDEFINED 





Undefined 


P_EVENT_DSCS_SETUP 


i 


The data session is going to be setup. 


P_EVENT_DSCS_ESTABLISHED 


2 


The data session is established by the network. 


P_EVENT_DSCS_QOS_CHANGED 


4 


A change in QoS class has taken place during 
the life of the data session. 
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1 1 .2.2 TpDataSessionMonitorMode 



Defines the mode that the call will monitor for events, or the mode that the call is in following a detected event. 



Name 


Value 


Description 


P_DATA_SESSION_MONITOR_MODE_INTERRUPT 





The data session event is intercepted by the data session control 

service and data session establishment is interrupted. The 

application is notified of the event and data session establishment 

resumes following an appropriate API call or network event (such 

as a data session release) 


P_DATA_SESSION_MONITOR_MODE_NOTIFY 


i 


The data session event is detected by the data session control 

service but not intercepted. The application is notified of the event 

and data session establishment continues 


P_DATA_SESSION_MONITOR_MODE_DO_NOT_MONITOR 


2 


Do not monitor for the event 



1 1 .2.3 TpDataSessionEventCriteria 

Defines the Sequence of Data Elements that specify the criteria for a event notification. 

Of the addresses only the Plan and the AddrString are used for the purpose of matching the notifications against the 
criteria. 



Sequence Element Name 


Sequence Element Type 


Description 


DestinationAclclress 


TpAddressRange 


Defines the destination address or address range for which the 
notification is requested. 


OriginatioriAddress 


TpAddressRange 


Defines the origination address or a address range for which the 
notification is requested. 


DataSessionEventName 


TpDataSessionE vent Name 


Name of the event(s) 


MonitorMode 


TpDataSessionMonitorMode 


Defines the mode that the Data Session is in following the 

notification. 

Monitor mode 

P_DATA_SESSION_MONITOR_MODE_DO_NOT_MONITOR 

is not a legal value here. 



1 1 .2.4 TpDataSessionEventlnfo 



Defines the Sequence of Data Elements that specify the information returned to the application in a Data Session 
event notification. 



Sequence Element Name 


Sequence Element Type 


Description 


DestinationAddress 


TpAddress 


Defines the destination address for which the notification is 
reported. 


OriginatingAddress 


TpAddress 


Defines the origination address for which the notification is 
reported. 


DataSessionEventName 


TpDataSessionEventName 


Name of the event(s) 


MonitorMode 


TpDataSessionMonitorMo 
de 


Defines the mode in which the Data Session is reporting the 

notification. 

Monitor mode 

P_DATA_SESSION_MONITOR_MODE_DO_NOT_MONITOR 

is not a legal value here. 


QoSClass 


TpDataSessionQosClass 


Defines the Quality of Service (QoS) class for the Data Session. 

QoSClass NULL is not a legal value when DataSessionEventName 

is set to P_EVENT_DSCS_QOS_CHANGED. For this particular 

event, the QoSClass defines the new QoS class effective after the 

change. 
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1 1 .2.5 TpDataSessionChargePlan 

Defines the Sequence of Data Elements that specify the charge plan for the call. 



Sequence Element Name 


Sequence Element Type 


Description 


Char geOrder Type 


TpDataSessionChargeOrder 


Charge order 


Currency 


TpString 


Currency unit according to ISO-4217:1995 [4] 


Additional Info 


TpString 


Descriptive string which is sent to the billing system without prior 
evaluation. Could be included in the ticket. 



Valid Currencies are: 

ADP, AED, AFA, ALL, AMD, ANG, AON, AOR, ARS, ATS, AUD, AWG, AZM, BAM, 

BBD, BDT, BEF, BGL, BGN, BHD, BIF, BMD, BND, BOB, BOV, BRL, BSD, BTN, 

BWP, BYB, BZD, CAD, CDF, CHF, CLF, CLP, CNY, COP, CRC, CUP, CVE, CYP, 

CZK, DEM, DJF, DKK, DOP, DZD, ECS, ECV, EEK, EGP, ERN, ESP, ETB, EUR, 

FIM, FJD, FKP, FRF, GBP, GEL, GHC, GIP, GMD, GNF, GRD, GTQ, GWP, GYD, 

HKD, HNL, HRK, HTG, HUF, IDR, IEP, ILS, INR, IQD, IRR, ISK, ITL, JMD, 

JOD, JPY, KES, KGS, KHR, KMF, KPW, KRW, KWD, KYD, KZT, LAK, LBP, LKR, 

LRD, LSL, LTL, LUF, LVL, LYD, MAD, MDL, MGF, MKD, MMK, MNT, MOP, MRO, 

MTL, MUR, MVR, MWK, MXN, MXV, MYR, MZM, NAD, NGN, NIO, NLG, NOK, NPR, 

NZD, OMR, PAB, PEN, PGK, PHP, PKR, PLN, PTE, PYG, QAR, ROL, RUB, RUR, 

RWF, SAR, SBD, SCR, SDD, SEK, SGD, SHP, SIT, SKK, SLL, SOS, SRG, STD, 

SVC, SYP, SZL, THB, TJR, TMM, TND, TOP, TPE, TRL, TTD, TWD, TZS, UAH, 

UGX, USD, USN, USS, UYU, UZS, VEB, VND, VUV, WST, XAF, XAG, XAU, XBA, 

XBB, XBC, XBD, XCD, XDR, XFO, XFU, XOF, XPD, XPF, XPT, XTS, XXX, YER, 

YUM, ZAL, ZAR, ZMK, ZRN, ZWD. 

XXX is used for transactions where no currency is involved. 



1 1 .2.6 TpDataSessionChargeOrder 

Defines the Tagged Choice of Data Elements that specify the charge plan for the call. 





Tag Element Type 






TpDataSessionChargeOrder Category 






Tag Element Value 


Choice Element Type 


Choice Element Name 


P_DATA_SESSION_CHARGE_PER_VOLUME 


TpChargePerVolume 


ChargePerVolume 


P_DATA_SESSION_CHARGE_NETWORK 


TpString 


NetworkCharge 



1 1 .2.7 TpDataSessionChargeOrderCategory 



Name 


Value 


Description 


P_DATA_SESSION_CHARGE_PER_VOLUME 





Charge per volume 


P_DATA_SESSION_CHARGE_NETWORK 


l 


Operator specific charge plan specification, e.g. charging table name / 
charging table entry 
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11.2.8 TpChargePerVolume 



Defines the Sequence of Data Elements that specify the time based charging information. The volume is the sum of 
uplink and downlink transfer data volumes. 



Sequence Element Name 


Sequence Element Type 


Description 


InitialCharge 


Tplnt32 


Initial charge amount (in currency units * 0.0001) 


CurrentChargePer Kilobyte 


Tplnt32 


Current tariff (in currency units * 0.0001) 


Next Char gePerKilobyte 


Tplnt32 


Next tariff (in currency units * 0.0001) after tariff switch. 
Only used in setAdviceOfCharge() 



1 1 .2.9 TpDataSession Identifier 

Defines the Sequence of Data Elements that unambiguously specify the Data Session object 



Sequence Element Name 


Sequence Element Type 


Sequence Element Description 


DataSessionRef erence 


IpDataSessionRef 


This element specifies the interface reference for the Data 
Session object. 


DataSessionID 


TpSessionID 


This element specifies the data session ID of the Data Session. 



11.2.10 TpDataSessionError 

Defines the Sequence of Data Elements that specify the additional information relating to a call error. 



Sequence Element Name 


Sequence Element Type 


ErrorTime 


TpDateAndTime 


ErrorType 


TpDataSessionErrorType 


Addi tionalErrorlnfo 


TpDataSessionAdditionalErrorlnf o 



1 1 .2.1 1 TpDataSessionAdditionalErrorlnfo 

Defines the Tagged Choice of Data Elements that specify additional Data Session error and Data Session error 
specific information. 





Tag Element Type 






TpDataSessionErrorType 






Tag Element Value 


Choice Element Type 


Choice Element Name 


P_DATA_SESSION„ERROR_UNDEFINED 


NULL 


Undefined 


P_DATA_SESSION_ERROR_INVALID_ADDRESS 


TpAddressError 


DataSessionErrorlnvalidAddress 


P_DATA_SESSION_ERROR_INVALID_STATE 


NULL 


Undefined 



11.2.12 TpDataSessionErrorType 

Defines a specific Data Session error. 



Name 


Value 


Description 


P_DATA_SESSION_ERROR_UNDEFINED 





Undefined; the method failed or was refused, but no specific reason can be 

given. 


P_DATA_SESSION_ERROR_INVALID_ADDRESS 


i 


The operation failed because an invalid address was given 


P_DATA_SESSION_ERROR_INVALID_STATE 


2 


The data session was not in a valid state for the requested operation 
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11.2.13 TpDataSessionFault 

Defines the cause of the data session fault detected. 



Name 


Value 


Description 


P_DATA_SESSION_FAULT_UNDEFINED 





Undefined 


P_DATA_SESSION_FAULT_USER_ABORTED 


i 


User has finalised the data session before any message could be sent by the 
application 


P__DATA_SESSION_TIMEOUT_ON_RELEASE 


2 


This fault occurs when the final report has been sent to the application, but 

the application did not explicitly release data session object, within a 

specified time. 

The timer value is operator specific. 


P_DATA_SESSION_TIMEOUT_ON_INTERRUPT 


3 


This fault occurs when the application did not instruct the gateway how to 

handle the call within a specified time, after the gateway reported an event 

that was requested by the application in interrupt mode. 

The timer value is operator specific. 



11.2.14 TpDataSessionReleaseCause 

Defines the Sequence of Data Elements that specify the cause of the release of a data session. 



Sequence Element Name 


Sequence Element Type 


Value 


Tplnt32 


Location 


Tplnt32 


NOTE: the Value and Location are specified as in ITU-T Recommendation Q.850. 



1 1 .2.1 5 TpDataSessionSupervise Volume 



Defines the Sequence of Data Elements that specify the amount of volume that is allowed to be transmitted for the 
specific connection. 



Sequence Element 
Name 


Sequence Element 
Type 


Sequence Element Description 


VolumeQuantity 


Tplnt32 


This data type is identical to a Tplnt32, and defines the quantity of the granted volume that 

can be transmitted for the specific connection. The volume specifies the sum of uplink and 

downlink transfer data volumes. 


VolumeUnit 


Tplnt32 


In Order to enlarge the range of the volume quantity value the exponent of a scaling factor 

(10 A VolumeUnit) is provided. 

When the unit is for example in kilobytes, VolumeUnit shall be set to 3. 



11.2.16 TpDataSessionSuperviseReport 

Defines the responses from the data session control service for calls that are supervised. The values may be combined 
by a logical 'OR' function. 



Name 


Value 


Description 


P_DATA_SESSION_SUPERVISE_VOLUME_REACHED 


01h 


The maximum volume has been reached. 


P_DATA_SESSION_SUPERVISE_DATA_SESSION_ENDED 


02h 


The data session has ended, either due to data 

session party to reach of maximum volume or 

calling or called release. 


P_DATA„SESSION_SUPERVISE_MESSAGE_SENT 


04h 


A warning message has been sent. 
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11.2.17 TpDataSessionSuperviseTreatment 



Defines the treatment of the call by the data session control service when the supervised volume is reached. The values 
may be combined by a logical 'OR' function. 



Name 


Value 


Description 


P_DATA_SESSION_SUPERVISE_RELEASE 


01 h 


Release the data session when the data session supervision volume is reached. 


P_DATA_SESSION_SUPERVISE_RESPOND 


02h 


Notify the application when the call supervision volume is reached. 


P_DATA_SESSION_SUPERVISE_INFORM 


04h 


Send a warning message to the originating party when the maximum volume 

is reached. If data session release is requested, then the data session will be 

released following the message after an administered time period 



1 1 .2.1 8 TpDataSessionReport 

Defines the Sequence of Data Elements that specify the data session report specific information. 



Sequence Element Name 


Sequence Element Type 


Mo nit or Mode 


TpDataSessionMonitorMode 


DataSessionE vent Time 


TpDateAndTime 


DataSessionReportType 


TpDataSessionReport Type 


AdditionalReport Inf o 


TpDataSessionAdditionalReportlnf o 



1 1 .2.1 9 TpDataSessionAdditionalReportlnfo 



Defines the Tagged Choice of Data Elements that specify additional data session report information for certain types of 
reports. 





Tag Element Type 






TpDataSessionReportType 





Tag Element Value 


Choice Element Type 


Choice Element Name 


P_DATA_SESSION_REPORT_UNDEFINED 


NULL 


Undefined 


P_DATA_SESSION_REPORT_CONNECTED 


NULL 


Undefined 


P_DATA_SESSION_REPORT_DISCONNECT 


TpDataSessionReleaseCause 


DataSessionDisconnect 



1 1 .2.20 TpDataSessionReportRequest 

Defines the Sequence of Data Elements that specify the criteria relating to data session report requests. 



Sequence Element Name 


Sequence Element Type 


MonitorMode 


TpDataSessionMonitorMode 


DataSessionReportType 


TpDataSessionReportType 



1 1 .2.21 TpDataSessionReportRequestSet 

Defines a Numbered Set of Data Elements of TpDataSessionReportRequest. 
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1 1 .2.22 TpDataSessionReportType 

Defines a specific data session event report type. 



Name 


Value 


Description 


P_DATA_SESSION_REPORT_UNDEFINED 





Undefined 


P_DATA_SESSION_REPORT_CONNECTED 


1 


Data session established. 


P_DATA_SESSION_REPORT_DISCONNECT 


2 


Data session disconnect requested by data session party 



1 1 .2.23 TpDataSessionEventCriteriaResult 



Defines a sequence of data elements that specify a requested data session event notification criteria with the associated 
assignmentlD. 



Sequence Element Name 


Sequence Element Type 


Sequence Element Description 


Event Criteria 


TpDataSessionEventCriteria 


The event criteria that were specified by the application. 


AssignmentlD 


TpAssignmentID 


The associated assignmentlD. This can be used to disable the 
notification. 



1 1 .2.24 TpDataSessionEventCriteriaResultSet 

Defines a set of TpDataSessionEventCriteriaResult. 
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Annex A (normative): 

OMG IDL Description of Data Session Control SCF 

The OMG IDL representation of this interface specification is contained in a text file (dsc.idl contained in archive 
2919808IDL.ZIP) which accompanies the present document. 
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Annex B (informative): 

W3C WSDL Description of Data Session Control SCF 

The W3C WSDL representation of this specification is contained in a text file (dsc.wsdl contained in archive 
2919808WSDL.ZIP) which accompanies the present document. 
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Annex C (informative): 

Java API Description of the Data Session Control SCF 

The Java API realisation of this specification is produced in accordance with the Java Realisation rules defined in Part 1 
of this specification series. These rules aim to deliver for Java, a developer API, provided as a realisation, supporting a 
Java API that represents the UML specifications. The rules support the production of both J2SE and J2EE versions of 
the API from the common UML specifications. 

The J2SE representation of this specification is provided as Java Code, contained in archive 2919808V550J2SE.ZIP 
that accompanies the present document. 

The J2EE representation of this specification is provided as Java Code, contained in archive 2919808J2EE.ZIP that 
accompanies the present document. 
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Annex D (informative): 
Change history 



Change history 


Date 


TSG# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


Mar 2001 


CN 11 


NP-010134 


047 


- 


CR 29.1 98: for moving TS 29.1 98 from R99 to Rel 4 (N5-01 01 58) 


3.2.0 


1.0.0 


Jun2001 


CN 12 


NP-010330 


001 


- 


Corrections to OSA API Rel4 


4.0.0 


4.1.0 


Sep 2001 


CN 13 


NP-010471 


002 


- 


Changing references to JAIN 


4.1.0 


4.2.0 


Dec 2001 j 


CN 14 


NP-010601 


003 


- 


Replace Out Parameters with Return Types 


4.2.0 


4.3.0 


Dec 2001 


CN 14 


NP-010601 


004 


- 


Corrections and alignment additions to the Data Session Control SCF 


4.2.0 


4.3.0 


Mar 2002 


CN_15 


NP-020110 


005 


— 


Add P_INVALID_INTERFACE_TYPE exception to 
lpService.setCallback() and IpService.setCallbackWithSessionlDO 


4.3.0 


4.4.0 


Jun 2002 


CN 16 


NP-020182 


006 


- 


Addition of support for WSDL realisation 


4.4.0 


5.0.0 


Jun 2002 


CN_16 


NP-020183 


007 


- 


Addition of Support for Network Controlled Notifications DSC 


4.4.0 


5.0.0 


Jun 2002 


CN 16 


NP-020192 


008 


- 


Adding missing text concerning the activity timer and criteria overlap 


4.4.0 


5.0.0 


Sep 2002 


CN_17 


NP-020435 


011 




Remove duplicate exception from 
IpDataSessionControlManager.createNotificationO 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020435 


012 




Remove P SERVICE INFORMATION MISSING and 
P_SERVICE_FAULT_ENCOUNTERED exceptions 
from DataSessionControl methods. 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020435 


013 




Introduce new method getNotifications to correct the result type of 
IpDataSessionControlManager.getNotificationO to permit retreival of 
all created notifications. 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020435 


014 




Add P_INVALID_INTERFACE_TYPE exception to 
IpDataSessionControlManager.createNotificationO, resulting in new 
createNotifications() method 


5.0.0 


5.1.0 


Sep 2002 


CN 17 


NP-020435 


015 




Add text to clarify requirements on support of methods 


5.0.0 


5.1.0 


Sep 2002 


CN 17 


NP-020435 


016 




Correction on use of NULL in Data Session Control API 


5.0.0 


5.1.0 


Sep 2002 


CN_17 


NP-020395 


017 




Add text to clarify relationship between 3GPP and ETSI/Parlay OSA 
specifications 


5.0.0 


5.1.0 


Mar 2003 


CN 19 


NP-030024 


019 


- 


Addition of status of methods to Data Session Control interfaces 


5.1.0 


5.2.0 


Mar 2003 


CN 19 


NP-030024 


021 


- 


Corrections to data types in Data Session Control 


5.1.0 


5.2.0 


Mar 2003 


CN_19 


NP-030034 


022 


- 


Inconsistent description of use of secondary callback 


5.1.0 


5.2.0 


Mar 2003 


CN_19 


NP-030034 


023 


- 


Promotion of TpDataSessionQosClass data type definition to the 
Common Data Types 


5.1.0 


5.2.0 


Jun 2003 


CN_20 


NP-030238 


025 


- 


Correction of the description for callEventNotify & reportNotification 


5.2.0 


5.3.0 


Sep 2003 


CN 21 


NP-030352 


026 


- 


Correction to Java Realisation Annex 


5.3.0 


5.4.0 


Apr 2004 


CN_23bis 


NP-040155 


028 


— 


Correct Java Code to conform with Java Rulebook in TS 29.198-01 
and to remove errors 


5.4.0 


5.5.0 
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